java - Apache Commons 电子邮件和 UTF-8
全部标签 我经常看到这种情况,但还没有想出一个优雅的解决方案。如果用户输入包含无效的字节序列,我需要能够让它不引发异常。例如:#@raw_responsecomesfromuserandcontainsinvalidUTF-8#forexample:@raw_response="\xBF"regex.match(@raw_response)ArgumentError:invalidbytesequenceinUTF-8已经问了很多类似的问题,结果似乎是对字符串进行编码或强制编码。然而,这些都不适合我:regex.match(@raw_response.force_encoding("UTF-8"
尽管thisthread话不多说,我想你是这样在Devise初始化程序中设置发件人姓名的:app/config/initializers/devise.rbDevise.setupdo|config|config.mailer_sender="'MySite'"end但这对我不起作用。有谁知道正确的做法吗? 最佳答案 就是这样:config.mailer_sender='"Example.com"' 关于ruby-on-rails-如何为电子邮件设置Devise发件人姓名,我们在Stac
我可以通过在其顶部添加注释行来指定任何ruby文件使用特定编码:#encoding:utf-8但是在Rails的config/application.rb中,我发现了这个:config.encoding="utf-8"它们有什么不同吗?如果我设置了config.encoding="utf-8",我还需要#encoding:utf-8吗? 最佳答案 config/application.rb中的config.encoding="utf-8"部分与Rails应如何解释内容有关。ruby文件中的#encoding:utf-8告诉rub
有没有办法从UTF-8编码的文件中删除BOM?我知道我所有的JSON文件都是用UTF-8编码的,但是编辑JSON文件的数据录入人员将它保存为UTF-8和BOM。当我运行我的Ruby脚本来解析JSON时,它因错误而失败。我不想手动打开超过58个JSON文件并转换为没有BOM的UTF-8。 最佳答案 对于ruby>=1.9.2,您可以使用模式r:bom|utf-8这应该有效(我还没有结合json测试它):json=nil#definethevariableoutsidetheblocktokeepthedataFile.open('
是否有任何gem可以自动将#encoding:UTF-8添加到每个Ruby文件?或者是否有任何其他方法可以防止整个RubyonRails项目(不仅在单个类中)出现invalidmultibytechar(US-ASCII)错误? 最佳答案 升级到Ruby2.0,因为它使UTF-8成为默认编码,从而消除了对魔术注释的需要。 关于Ruby:如何自动添加"#encoding:UTF-8"?,我们在StackOverflow上找到一个类似的问题: https://st
我目前正在使用RSpec测试我的邮件程序,但我已经开始按照Rails指南中的说明设置多部分电子邮件:http://guides.rubyonrails.org/action_mailer_basics.html#sending-multipart-emails我有文本和html格式的邮件程序模板,但看起来我的测试只检查HTML部分。有没有办法单独检查文本模板?它是否只检查HTMLView,因为它在默认顺序中是第一个? 最佳答案 为了补充nilmethod的出色答案,您可以通过使用共享示例组测试文本和html版本来清理规范:spec_
如何从ruby字符串中删除非UTF8字符?我有一个字符串,其中包含例如“xC2”。我想从字符串中删除该字符,使其成为有效的UTF8。这个:text.gsub!(/\xC2/,'')返回错误:incompatibleencodingregexpmatch(ASCII-8BITregexpwithUTF-8string)我也在查看text.unpack('U*')和string.pack,但没有得到任何结果。 最佳答案 您可以为此使用编码。text.encode('UTF-8',:invalid=>:replace,:undef=>
我在我的Controller中收到有关此代码的EOFError(文件结束错误)。出现错误的block位于UserMailer.deliver_message(我不知道如何解决这个问题的行的末尾,我已经被困了大约2个月,有人建议这个网站。请帮忙。defcontact@title="ContactUs"ifrequest.post?@message=Message.new(params[:contact])if@message.valid?UserMailer.deliver_message(:message=>@message)flash[:notice]="Thankyouforcon
我有一个Rails项目,里面有很多西里尔字符串。它在Ruby1.8上运行良好,但Ruby1.9假定源文件是US-ASCII编码的,除非您在源文件顶部提供#encoding:utf-8注释。此时文件不被视为US-ASCII。是否有更简单的方法告诉Ruby“此应用程序是UTF8编码的。请将所有和任何包含的源文件视为UTF8,除非另有声明”?更新:我写了“Howtoinserttheencoding:UTF-8directiveautomaticallyinRuby1.9files”,它会在需要时自动附加编码指令。 最佳答案 我觉得你可以
tvdb中的汉尼拔剧集里有奇怪的角色。例如:Œuf于是ruby吐出:./manifesto.rb:19:in`encode':"\xC3"fromASCII-8BITtoUTF-8(Encoding::UndefinedConversionError)from./manifesto.rb:19:in`to_json'from./manifesto.rb:19:in`'第19行是:puts@tree.to_json有没有办法处理这些非utf字符?我宁愿不替换它们,而是转换它们?还是无视他们?我不知道,感谢任何帮助。奇怪的是脚本通过cron运行良好。手动运行它会产生错误。